WD57C65 Floppy Disk Subsystem 
Controller 


FEATURES 
e IBM* PS/2* and IBM PC XT* Compatible 
¢ 100% Software Compatible with WD37C65B 


¢ Integrated High Performance DPLL Data 
Separator 
—<10E-9 industry standard error rates 
—Data rates of 125, 250, 300, 500 
Kbits/second 
Automatic Write Precompensation 
—Defeat option 
—Programmable values of 62,125,187, and 
250 nanoseconds for standard data rates. 
¢ On Chip Clock Generation 
—Two TTL clock inputs (44 pin PLCC) 
—One XTAL oscillator circuit for standard 
data rates. 
Enhanced Host Interface 
—Read/write accesses compatible with an 8 
or 12 MHz 286 microprocessor with 0 wait 
states 
—Twenty LSTTL output drive capability 


—TTL Schmitt trigger inputs (except Data 
Bus 


Direct Floppy Disk Drive Interface - No Buffers 
Needed 
—48mA sink output drivers 
—Schmitt trigger input line receivers 
—Supports three drives 
Complete Application Support for Systems 
Compatible with the IBM PS/2 and IBM PC XT. 
—Register file on chip. 
—PC XT mode provides required signal 
qualification to DMA channel 
—BIOS compatible 


DESCRIPTION 


The WD57C65 Floppy Disk Subsystem Controller 
is an LSI device which incorporates all the func- 
tional blocks that typically make up a floppy disk 
subsystem controller, such as the formatter/con- 
troller, data separation, write precompensation, 
data rate selection, clock generation, and floppy 
drive interface drivers and receivers. Traditionally, 
data rate selection, drive selection, and motor 
control have been output ports of the host 
processor’s architecture. The WD57C65 provides 
all the necessary status and control registers 


necessary to integrate all the functions of the flop- 
py disk subsystem on a single chip. 


The WD57C65 is designed for systems com- 
patible with the IBM PS/2 and IBM PC XT and in- 
terfaces with three 5.25 or 3.5-inch floppy disk 
drives. It is available in a 40-pin, totally encapsu- 
lated plastic DIP or a 44-pin PLCC package. 


The WD57C65 retains the core of the WD37C65B 
floppy disk controller so that the Micro-Sequencer 
is functionally equivalent and all commands will 
execute identically to ensure software com- 
patibility. The Control State Machine is also func- 
tionally equivalent. The Micro-Sequencer and the 
Control State Machine operate at eight times the 
selected bit data rate in MFM and sixteen times 
the bit data rate in FM. 


Figure 1 shows a block diagram of the WD57C65 
"superchip". 


Host Interface 

The host interface provides the standard host ac- 
cess signals (eight control signals and eight data 
signals), but with enhanced timing. A detailed in- 
terface description appears in the Interface sec- 
tion of this document. 


Floppy Drive Interface 

The floppy drive interface provides data separa- 
tion that has been designed to address high-per- 
formance error rates on floppy disk drives. It con- 
tains all the necessary logic to achieve 2nd order, 
type 2, phase-locked loop performance. Write 
precompensation is included along with the usual 
formatting, encoding/decoding, stepper motor 
control, and status sensing functions. A detailed 
interface description appears in the Interface sec- 
tion of this document. 


Clock and Timing Generator 

This logical block provides all the clocks needed 
by the WD57C65: Master Clock, Write Clock and 
Sampling Clock. Sampling Clock (SCLK) is the 
clock which drives the digital phase lock loop data 
separator that is used during data recovery. This 
clock frequency is always 32 times the selected 
data rate. The encoder logic uses the Write Clock | 
(WCLK) to place MFM or FM on the serial Write 
Data stream to the disk. WCLK always has a fre- 
quency two times the selected data rate. Master 
clock (MCLK) is used by the microsequencer. 
MCLK and MCLK/ clock all latches in a two-phase 
scheme. One microinstruction cycle is four MCLK 
cycles. MCLK has a frequency equal to eight 
times the selected MFM data rate or 16 times the 


“IBM and PS/2 are registered trademarks; and XT is a trademark of International Business Machines Corporation. 
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FIGURE 1. WD57C65 BLOCK DIAGRAM 


TABLE 1. CLOCK DATA RATE 


DATA RATE 


500 kb/s 
250 kb/s 
250 kb/s 
125 kb/s 
300 kb/s 


16.0 MHz 
8.0 MHz 
8.0 MHz 
4.0 MHz 
9.6 MHz 


1.0 MHz 
500 KHz 
500 KHz 
250 KHz 
600 KHz 


16.0 MHz +/- 100 ppm 

R series = 30 Ohms maximum 
C shunt = 10 pf maximum 

C3 = 47 pf 5% mica 

C4 = 15 pf 5% mica 


FIGURE 2. XTAL OSCILLATOR CIRCUITS FOR THE 44-PIN PLCC 


FM data rate. Table 1 presents the Clock Data 
Rates. Figure 2 illustrates the XTAL oscillator cir- 
cuits for the 44-pin PLCC configuration. 


Crystal and Clock Input 

An XTAL oscillator circuit (Figure 2) provides the 
necessary signal for internal timing when using 
the 44-pin PLCC package. There is one 16 Mhz 
oscillator on the WD57C65 which handles all 
standard data rates (500, 250, 125 Kbits/sec) and 
one TTL level clock input used for non-standard 
data rates; e.g. 300 Kbits/second used in PC AT* 
designs. Note, however, that the WD57C65 
does not support the IBM PC AT due to 
register address mapping conflicts. 


When using the 40-pin DIP, one TTL level clock 
input handles the standard data rates. The 40-pin 
DIP does not support non-standard rates. 


* AT is a registered trademark of International Business Machines Corporation. 


Write Precompensation 

The WD57C65 maintains the standard first level 
algorithm to determine when write precompensa- 
tion should be applied. These EARLY and LATE 
signals are used internally to select the ap- 
propriate delay in the Write Data pulse stream. 
The encoded write data signal is synchronized to 
the 16 MHz clock, if this is the frequency on pin 
XTAL, and clocked through a shift register. 
Signals EARLY, NOM, and LATE determine the 
amount of delay through the shift register before a 
multiplexer gates the chosen bit to the output. The 
output data pulse width has 25% duty cycle, i.e. 
one-fourth of the bit cell period, also equal to half 
of the WCLK period. 


The Write Precompensation value is micro 
programmable. The precompensation values are 


defined by two bits in the Options Register (bit 2 
and 3). After reset the default value for Precom- 
pensation is +/- two clocks and is valid for all 
tracks. There is no write precompensation value 
for FM. Precompensation can be disabled by the 
use of bit 2 in the Configuration Control Register 
for models compatible with the IBM PS/2 Model 
30. For models compatible with the IBM PS/2 
Models 50,60 and 80, bit 4 in the Options Register 
disables Write precompensation. The precompen- 
sation value is independent of track. 


Data Separator 


The Data Separator is a WD92C32 Digital Phase 
Lock Loop Floppy Disk Data Separator (DPLL). It 
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was designed to address high performance error 
rates on floppy disk drives, and to provide supe- 
rior performance in terms of available bit jitter 
tolerance. It contains the necessary logic to 
achieve classical 2nd order, type 2, phase-locked 
loop performance. Figure 3 is a_ simplified 
block diagaram of the WD92C32. The bit jitter 
tolerance for the data separator is 60%, which 
guarantees an error rate of <10E-9. 


WD57C65 Registers 

The WD57C65 provides nine registers for status, 
control, option selection and buffering functions. 
These registers are described in detail in the In- 
terface Description. 
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FIGURE 3. WD92C32 SIMPLIFIED BLOCK DIAGRAM 


INTERFACE DESCRIPTION 


Figures 4 and 5 show the pinouts of the floppy subsystem controllers for systems compatible with the 
IBM PS/2. Table 2 provides a pinout signal description of the WD57C65. 
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FIGURE 5. WD57C65 44-PIN PLCC 


Table 2 below lists the DIP/PLCC pin numbers and the corresponding signal and signal function descrip- 
tion. Note: For pin numbers separated by a "/", the first number is a DIP pin number. The number follow- 
ing the slash is the PLCC pin number. | | 
TABLE 2. PINOUT DESCRIPTION | 

D/P PIN MNEMONIC SIGNAL NAME ie) DESCRIPTION 


| Control signal for transfer of data or status onto the 
data bus by WD57C65. 


Control signal for latching data from the bus into 
WD57C65 buffer register. Also other registers of 
Write - only type. 


3 Chip Select Enables RD/ or WR/ operation from the host. 


4-6 - Address Address lines selecting data. 
7-10,12-15 - Data Bus 8 bit bi-directional tri-state data bus. 


11 | +5V Supply 


16 Direct Memory- DMA request for byte transfers of data. In a mode 
| Access compatible with the IBM PC XT and IBM PS/2 Model 
30, this pin is tri-stated, enabled by DMAEN signal 
from the Digital Output register. In modes compatible 
with the IBM PS/2 Models 50, 60 and 80, this internal 

signal, DMAEN, is always forced valid. 


Interrupt Request Interrupt request indicating completion IRQ/ of com- 
mand execution or data transfer requests (in non- 
DMA mode). In modes compatible with the IBM PC 
XT and PS/2 model 30, this pin is tri-stated, enabled 
by DMAEN signal from the Digital Output register 
and is active high. It is open drain for modes com- 
patible with the IBM PS/2 Models 50, 60 and 80, re- 
quires external pull-up, and is active low. 


DMA Acknowledge Used by DMA controller to transfer data from 
WD57C65 onto the bus. Logical equivalent to CS/ 
and Addr=101 . In a mode compatible with the IBM 
PC XT and IBM PS/2 Model 30, this signal is 
qualified by DMAEN from the Digital Output register. 
In modes compatible with the IBM PS/2 Model 50, 60 
and 80, this signal is not qualified. 


Terminal Count This signal indicates to WD57C65 that TC/ data 
transfer is complete. TC is always qualified by 
DACK/. In the IBM PC XT and IBM PS/2 Model 30, 
qualification by DACK/ requires Digital Output 
Register signal DMAEN to be logically true. In the 
IBM PS/2 models 50, 60 and 80, TC is active low, 
ie the internal signal DMAEN is always forced 
valid. 


16 MHz TTL level clock input used to generate all in- 
ternal timings for standard data rates. Non-standard 
data rates (300 Kbits/second) are not supported by 
the 40-pin dip package. 
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TABLE 2. PINOUT DESCRIPTION (CONTINUED) 


D/P PIN MNEMONIC SIGNAL NAME VO DESCRIPTION 


NA/20 CLK2 Clock 2 | TTL level clock input used for non-standard data 
rates, such as 300 Kbits/second in an IBM PC AT 
application. Must be 32 times MFM data rate; i.e. 9.6 
MHz for 300 Kbits/second, and can only be selected 
from the Control Register. It has an internal pull-up. 


NA/21 XTAL XTAL | Oscillator input requiring 16MHz crystal. This oscil- 
lator is used for all standard data rates. It may be 
driven with a TTL level signal. 


NA/22 XTAL/ XTAL OQ XTAL oscillator drive output fro 44-pin PLCC. 

21/23 RST Reset | Resets controller, placing micro-sequencer in idle. 
Resets device outputs. 

22/24 PCMODE PC MODE | PC application mode select. Selects a mode com- 


patible with the IBM’s PC XT and IBM PS/2 Model 
30, or a mode compatible with the IBM PS/2 Models 
50, 60 and 80. 


23/25 RDD/ Read Disk Data | This Schmitt Trigger (ST) input senses the serial bit 
stream from the disk drive. The falling edge of each 
pulse represents a flux transition of the encoded 


data. 
24/26 WCSEL Write Control | Allows direct interface to both 5.25 and 3.5-inch flop- 
Select py disk drives. For logical function see Table 3. 
NA/27 MOEN2/ Floppy Drive O This high current driver (HCD) output, when active 
Motor Enable low, enables disk drive #2. This signal comes from 
Digital Output Register. 
25/28 MOEN1/ Floppy Drive OQ This HCD output, when active low, enables disk 
Motor Enable drive #1. This signal comes from Digital Output 
Register. 
26/29 MOENO/ Floppy Drive O This HCD output, when active low, enables disk 
Motor Enable drive #0. This signal comes from Digital Output 
Register 
27/30 HS/ Head Select OQ This HCD output selects the head, or side of the flop- 
py disk that is being read or written. Logic 1 = side 0, 
logic 0 = side 1. 
28/31 WE/ Write Enable OQ This HCD output goes active low just prior to writing 


on the diskette. This allows current to flow through 
the write head. 


29/32 WD/ Write Data OQ This HCD output is write data. Each falling edge of 
the encoded data pulse stream causes a flux transi- 
tion on the media. 


30/33 STEP/ Step OQ This HCD output issues an active low pulse for each 
track-to-track movement of the head. The state of 
the Direction signal at the trailing edge of the STEP 
pulse determines the direction of the head motion. 


mimi ie 
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TABLE 2. PINOUT DESCRIPTION (CONTINUED) | 
D/P PIN MNEMONIC | SIGNAL NAME DESCRIPTION - 


Ground 


Direction Control This HCD output determines the direction of the 
head stepper motor. Logic 1 = outward motion, logic 
0 = inward motion. 


High Density This HCD output indicates to -the drive the ap- 

Select propriate write current level to use for the data rate 
and media density currently being used. The active 
logic level used to select between High Density vs 
Double Density is determined by the WCSEL input 
pin. 

Drive Select 0 This HCD output, when active low, enables Drive O’s 
interface. This signal comes from the Digital Output 
register. This signal is qualified by MOENO/ active 
low. 


Drive Select 1 This HCD output, when active low, enables Drive 1’s 
interface. This signal comes from the Digital Input 
register. This signal is qualified by MOEN1/ active 
low. 


Drive Select 2 This HCD output, when active low, enables Drive 2’s 
interface. This signal comes from the Digital input 
Digital Input register. This signal is qualified by 
MOENZ/ active low. 


Diskette Change This is a Schmitt Trigger input which is an active low 
signal when the disk drive door is open or if the dis- 
kette has possibly changed since last drive selection. 
This status is reflected in the Digital Input Register. 


Write Protected This Schmitt Trigger input indicates status from the 
disk drive, going active low when a diskette is Write 
Protected. : 


Track 00 This Schmitt Trigger input indicates status from the 
drive, going active low when the head is positioned 
over the outermost track, track 00. 


This Schmitt Trigger input indicates status from the 
drive, going active low when the head is positioned 
over the beginning of a track marked by an index 
hole. 


Twp Floppy Drive This Schmitt Trigger input indicates status from the 
drive, going active low when a second drive is in- 
stalled. 


WD57C65 
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Note: High impedance 
(3.5 inch) drives require 
1.5K Ohm pull-ups on 

all outputs to drive. Low 
impedance drives (5.25 
inch) do not require pull- 
ups. 


VSS 34 


i = Indicates a 1.5 K Ohm pull-up resistor 
FIGURE 6. TYPICAL WD57C65 SYSTEM 


Figure 6 illustrates a typical interface system for 
the WD57C65. 


Floppy Drive Interface 


The WD57C65 Floppy Drive Interface provides 
different options than its predecessor, the 
WD37C65B. Most notably, it supports three drives 
rather than just two. A new input signal, Write 
Control Select (WCSEL) allows interfacing with 
5.25 and 3.5 inch floppy drives. WCSEL and the 
selected data rate determine the correct logical 
level on the High Density Select (HDS/) output 
pin. If WCSEL = 0, HDS/ = CRO/. If WCSEL =1, 
HDS/ = CR1. Refer to Table 3, HDS Truth Table. 


PCMODE input signal selects either IBM PC XT- 
PS/2 30 mode or the PS/2 50, 60, and 80 mode. 
WD57C65 does not support IBM AT systems. 


Since PS/2 compatible systems require a Two 
Poppy Drive (TFD/) pin, the WD57C65 provides 
TFD/ and has dropped the PCVAL pin used 
for precompensation in the WD37C65B predeces- 
sor. Write precompensation values are deter- 
mined by bits 2 and 3 in the Options Register. The 
reset default value for write precompensation is 


+/- 2 clocks. 


TABLE 3. HDS TRUTH TABLE 


500 K MFM or 
250 K FM 


1 


250 K MFMor 
125 K FM 


Host Interface 


Host Microprocessor Peripheral Bus provides 
eight control signals and eight data signals. In the 
XT and PS2 30 mode, IRQ and DMA Request are 
tri-stated and enabled by DMAEN, which is inter- 
nally provided by the Digital Output Register. In 
PS/2 50, 60 and 80 mode, IRQ is open drain, ac- 
tive low, requires external pull-up, and DMAEN is 
always forced valid. The data bus, DMA, and IRQ 
outputs are designed to handle 20 LSTTL loading. 
Inputs, except the data bus, are Schmitt trigger 
receivers and can be hooked up to a bus or back- 
plane without any additional buffering. 


During the command or result phases, the Main 
Status Register must be read by the processor 
before each byte of information is written into or 
read from the Data Register. After each byte of 
data is read from or written into the Data Register, 
the CPU should wait for 12 microseconds before 
reading the Main Status Register. Bits D6 and D7 
in the Main Status Register must be in a "0" and 
"{" state, respectively, before each byte of the 
command word may be written into the 
WD57C65. Many of the commands require multi- 
ple bytes. As a result, the Main Status Register 
must be read prior to each byte transfer to the 
WD57C65. During the result phase, Bits D6 and 
D7 in the Main Status Register must both be "1’s" 
before reading each byte from ihe Data Regisier. 


DATA RATE AND CODE | WCSEL DESCRIPTION 
0 1 
1 0 


0 1 
1 1 
1 1 


5.25" High Density / 1.2 MByte FDD 
3.5" High Density / 1.44 MByte FDD 


5.25" Double Density / 1.2 MByte FDD 
Not Defined 


5.25" Double Density / 360 KByte FDD 
3.5" Double Density / 720 KByte FDD 
or 1.44 MByte FDD 


5.25" Single Density / 360 KByte FDD 
3.5" Single Density / 720 KByte FDD 


Note that this reading of the Main Status Register 
before each byte transfer to the WD57C65 is re- 
quired only in the command and result phases, 
and not during the execution phase. Note also 
that DB6 and DB7 in the MSR can be polled in- 
stead of waiting 12 microseconds. 


During the execution phase, the Main Status 
Register need not be read. If the WD57C65 is in 
the non-DMA mode, then receipt of each 
data byte (WD57C65 is reading data from the 
FDD) is indicated by an interrupt signal on pin 17 
(IRQ=1). The generation of a Read signal (RD=0) 
will clear the interrupt as well as output the data 
onto the data bus. If the processor cannot handle 
interrupts fast enough (every 13 microseconds for 
the MFM mode and 27 microseconds for the FM 
mode), then it may poll the Main Status 
Register and bit D7 (RQM) functions as the inter- 
rupt signal. If a Write command is in process, then 
the WR signal performs the reset to the Interrupt 
signal. 

All timing mentioned above is double for mini- 
floppy (5.25-inch) data rates. 


Note that in the non-DMA mode it is necessary to 
examine the Main Status Register to determine 
the cause of the interrupt since it could be a data 
interrupt or a command termination interrupt, 
either normal or abnormal. If the WD57C65 is in 
the DMA mode, no interrupt signals are generated 
during the execution phase. The WD57C65 


TABLE 4. ADDRESS REGISTER MAP 


ADDRESS MAP 


Status Register A 

Status Register B 

Digital Output Register 

Not Defined 

Main Status Register 

Main Data Register 

Options Register 

Digital Input Register 
Configuration Control Register 


OOOO 0O 000 0 


generates DMA requests when each byte of data 
is available. The DMA controller responds to this 
request with both DACK/ = 0 (DMA Acknowledge) 
and a RD/ =0 (Read signal). When the DMA Ack- 


nowledge signal goes low (DACK/ = 0), then the 
DMA Request is cleared (DMA = 0). If a Write 
Command has been issued, then a WR signal will 
appear instead of RD. After the execution phase 
has been completed (Terminal Count has oc- 
curred or the EOT sector is read or written), then 
an interrupt occurs (IRQ = 1). This signifies the 
beginning of the Result phase. When the first byte 
of data is read during the result phase, the Inter- 
rupt automatically clears (IRQ = 0). 


The RD/ or WR/ signals should be asserted while 
DACK/ is true. The CS/ signal is used in conjunc- 
tion with RD/ and WR’ as a gating function during 
programmed |/O operations. CS has no effect 
during DMA operations. If the non-DMA mode is 
chosen, the DACK/ signal should be pulled up to 
VCC. During the result phase all bytes shown in 
the Command Table must be read. The Read 
Data Command, for example, has several bytes of 
data in the result phase. All seven bytes must be 
read in order to successfully complete the Read 
Data command. The WD57C65 will not accept a 
new command until all seven bytes have been 
read. Other commands may require fewer bytes 
to be read during the result phase. The 
WD57C65 contains an address decoder for the 
register file on the host interface side. The ad- 
dress mapping is shown in Table 4. The Main 
Status Register mentioned may be read by the 
processor at any time. The other four Status 
Registers (STO, ST1, ST2, and ST3) are available 


elem |e] wm 


Read only 
Read only 
Write only 
Not defined 
Read only 
Read/Write 
Write only 
Read only 
Write only 
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only during the result phase and may be read 
only after completing a command. The particular 
command that has been executed determines 
how many of the status registers will be 
read. 


The bytes of data which are sent to the WD57C65 
during the command phase, and are read out of 
the WD57C65 in the result phase, must occur in 
the order shown in the Command Table. The 
command code must be sent first and the other 
bytes sent in the prescribed sequence. No fore- 
shortening of the command or result phases is al- 
lowed. After the last byte of data in the command 
phase is sent to the WD57C65, the execution 
phase automatically starts. In a similar fashion, 
when the last byte of data is read out in the result 
phase, the command is automatically ended and 
the WD57C65 is ready for a new command. 


Configuration Control Register 


The Configuration Control Register provides sup- 
port logic that latches the three least significant 
bits of the data bus upon receiving CS/ Address = 
111 and WR/. These bits select the desired data 
rate, which in turn controls the internal clock 
generation. Clock switchover is __ internally 
"deglitched,” allowing continuous operation after 
changing data rates. If the Configuration Control 
Register is not used, the data rate is 
governed by the supplied clock or crystal. The fre- 
quency must be 32 times the desired MFM data 
rate up to a maximum frequency of 16 MHz. This 
implies a maximum data rate of 500 kbits/second, 
ae the Configuration Control Register is 
used. 


Switching this clock must be "glitchless” or the device will need to be reset. Tables 5 and 6 show the 
Configuration Control Register. 


| TABLE 5. CONFIGURATION CONTROL REGISTER FOR SYSTEMS COMPATIBLE WITH IBM PS/2 50, 60 & 80 


BIT SIGNAL NAME / FUNCTION STORAGE RESET CLOCK 
= ELEMENT | CONDITION | QUALIFIER 


Data Rate None (1) 
Data Rate None (1) 
Reserved None 


Reserved None 
Reserved None 
Reserved | None 
Reserved None 
Reserved None 


NO OTR OD —+ © 


Note 1: 250K data rate is selected if bits 0 and 1 are anything but "0,0" in models compatible 
with the IBM PS/2 50, 60 and 80. 


TABLE 6. CONFIGURATION CONTROL REGISTER FOR SYSTEMS COMPATIBLE WITH IBM PC XT & PS/2 30. 


BIT SIGNAL NAME / FUNCTION STORAGE RESET CLOCK 
ELEMENT | CONDITION | QUALIFIER 
(3) 


0 Data Rate None 
1 Data Rate F/F 0 None 
2 No Write Precompensation F/F 0 None 
3 Reserved None N/A None 
4 Reserved ~ None N/A None 
5 Reserved | None N/A None 
6 Reserved None N/A None 
7 Reserved 


Note 3: Undefined in applications compatible with IBM PS/2 30, but supported by the 57C65. 
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TABLE 7. DATA RATE SELECTION 


DATA RATE | COMMENTS 


MFM, RST default (Defined in both modes) 

FM (Undefined in PC applications) 

MFM (Defined in applications compatible with IBM PC/AT) 
MFM (Defined in modes compatible with PC XT and PS/2) 
FM (Undefined in PC applications) 
FM (Undefined in PC applications) 


CR1 


Bit 2 (CR2) is undefined in the IBM PS/2 50, 60 and 80 modes, and is set toa "1". 


Bit 4 (CR4) enables (0) or disables (1) write precompensation in the IBM PS/2 50, 60 and 80 
mode. 


In the IBM PC XT and PS/2 30 mode, CR2 enables (0) or disables (1) write precompensation 


Main Status Register DIO and RQM getting set is 12 microseconds if 
500 kbits/second MFM data rate is selected. (If 


The Main Status Register is an eight-bit register ; 
that contains the status information of the FDC, ee ror this ee eee 


and may be accessed at any time. Only the Main Main Status Reai 

gister is read, the CPU 
Status Register may be read and used to — ghould wait 12 microseconds. The maximum time 
facilitate the transfer of data between the proces- —_— from the trailing edge of the last RD/ in the result 
sor and WD57C65. The DIO and RQM bits inthe ~~ Ghase to when DB4 (FDC busy) goes low is 12 
Main Status Register indicate when data is ready microseconds. Tables 8 through 12 show the bits 
and in which direction data will be transferred on in the Master Status Register and Status 
the data bus. The maximum time between the last Registers 0 through 3 
RD or WR during a command or result phase and 
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TABLE 8. MAIN STATUS REGISTER BITS 
BIT 


"NO. |_NAME__| SYMBOL cumbia 


FDD 0 BUSY FDD number is 0 in the Seek Mode. If any of the bits is set, 
FDC will not accept READ or WRITE commands. 


FDD 1 BUSY FDD number 1 is in the Seek Mode. If any of the bits is set, 
FDC will not accept READ or WRITE commands. 


FDD 2 BUSY FDD number 2 is in the Seek Mode. If any of the bits is set, 
FDC will not accept READ or WRITE commands. 


FDD 3 BUSY FDD number 3 is in the Seek Mode. If any of the bits is set, 
FDC will not accept READ or WRITE commands. 


FDC BUSY A READ or WRITE command is in progress. FDC will not 


accept any other command. 


EXECUTION MODE This bit is set only during Execution phase in non-DMA mode. 
- When DB5 goes low Execution phase has ended and Results 
Phase has started. It operates only during non-DMA mode 

of operation. | 


DATA INPUT Indicates direction of data transfer between FDC and Data 
Register. If DIO=1, then transfer is from Data Register to the 
processor. If DIO=0, then transfer is from the processor to 
Data Register. 


REQUEST FOR Indicates Data Register is ready to send or receive data to 

MASTER or from the processor. Both bits DIO and RQM should be 
used to perform the handshaking functions of “‘ready” and 
“direction” to the processor. 


TABLE 9. STATUS REGISTER 0 BITS 
BIT 


| _NO.|._NAME | SYMBOL ee 


D7=0 and D6=0. Normal termination of command was 
completed and properly executed. 
D7=0 and D6=1. Abnormal termination of command, (AT). 


D7 INTERRUPT CODE IC Execution of command was started but was not successfully 
completed. 
D6 D7=1 and D6=0. 


Invalid command issue, (IC). Command which was issued 
was never started. 


D5 SEEK END SE When the FDC completes the SEEK command, this flag is 
set to 1 (high). 
+tD4 EQUIPMENT CHECK EC If the Track 0 signal fails to occur after 255 step pulses 
3 (Recalibrate Commanda), then this flag is set. 
tD3 NOT READY NR Since drive Ready is always presumed true, this will always 
be a logic 0. 
D2 HEAD SELECT HS This flag is used to indicate the state of the head at interrupt. 
D1 UNIT SELECT 1 USt This flag is used to indicate a Drive Unit Number at interrupt. 
DO UNIT SELECT 0 USO This flag is used to indicate a Drive Unit Number at interrupt. 
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TABLE 10. STATUS REGISTER 1 BITS 


END OF CYLINDER 


DATA ERROR 


OVERRUN 


NO DATA 


NOT WRITEABLE 


MISSING ADDRESS 
MARK 


DESCRIPTION 


When the FDC tries to access a sector beyond the final sector 
of a cylinder, this flag is set. 


Not used. This bit is always 0 (low). 


When the FDC detects a *CRC error in either the ID field 
or the data field, this flag is set. 

If the FDC is not serviced by the host system during data 
transfers within a certain time interval, this flag is set. 
Not used. This bit is always O (low). 

During execution of READ DATA, WRITE DELETED DATA, 
or SCAN command, if the FDC cannot find the sector 
specified in the * *IDR Register, this flag is set. During 
execution of the READ ID command, if the FDC cannot read 
the ID field without an error, then this flag is set. 

During execution of the READ A TRACK command, if the 
starting sector cannot be found, then this flag is set. 
During execution of WRITE DATA, WRITE DELETED DATA 
or FORMAT A TRACK commands, if the FDC detects a WP 
signal from the FDD, then this flag is set. 

If the FDC cannot detect the ID Address Mark. after 
encountering the index hole twice, then this flag is set. 

If the FDC cannot detect the Data Address Mark or Deleted 
Data Address Mark, this flag is set. At the same time the 
MD (Missing Address Mark in data field) of Status Register 
2 is set. 
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TABLE 11. STATUS REGISTER 2 BITS 


xo Nan sor ee 


Not Used. This bit is always 0 (low). 


CONTROL MARK During execution of the READ DATA or SCAN Command, 
if the FDC encounters a sector which contains a Deleted Data 
Address Mark, this flag is set. 

DATA ERROR If the FDC detects a CRC error in the data field, then this 
flag is set. 

WRONG CYLINDER This bit is related to the ND bit, and when the contents of 
* * *C on the medium is different from that stored in the 
IDR, this flag is set. 

SCAN EQUAL During execution of the SCAN command, if the condition 
of “equal” is satisfied, this flag is set. 

SCAN NOT During execution of the SCAN command, if the FDC cannot 
find a sector on the cylinder which meets the condition, then 
this flag is set. 

BAD CYLINDER This bit is related to the ND bit, and when the contents of 
C on the medium is different from that stored in the IDR and 
the contents of C is FF, then this flag is set. 

MISSING ADDRESS When data is read from the medium, if the FDC cannot find 

MARK IN DATA FIELD a Data Address Mark or Deleted Data Address Mark, then 
this flag is set. 


TABLE 12. STATUS REGISTER 3 BITS 


xo [vane ror ee 


~ Not used. Will always be logic 0. 


WRITE PROTECTED This bit is used to indicate the status of the WRITE 
PROTECTED signal from the FDD. 


READY This bit will always be a logic 1. 
Drive is presumed to be ready. 


TRACK 0 This bit is used to indicate the status of the Track O signal 
from the FDD. 


WRITE PROTECTED WP This bit is used to indicate the status of the WRITE 


PROTECTED signal from the FDD. 


HEAD SELECT This bit is used to indicate the status of the Side Select signal 
to the FDD. 


UNIT SELECT 1 This bit is used to indicate the status of the Unit Select 1 
signal to the FDD. 


UNIT SELECT 2 This bit is used to indicate the status of the Unit Select 0 
signal to the FDD. 
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Status Register A (CS/ = 0 and Address = 000 - Read Only) 


TABLE 13. STATUS REGISTER A FOR SYSTEMS COMPATIBLE WITH IBM PS/2 50, 60 AND 80 


SIGNAL NAME / FUNCTION 


+ Direction 

- Write Protection 

- Index 

+ Head 1 Select 

- Track 0 

+ Step 

- 2nd Drive Installed 
Interrupt 


NOP WN —- © 


STORAGE 
ELEMENT 


TSB N/A None 
TSB N/A None 
TSB N/A None 
TSB N/A None 
TSB N/A None 
TSB N/A None 
TSB N/A None 


TABLE 14. STATUS REGISTER A FOR SYSTEMS COMPATIBLE WITH THE IBM PC XT AND IBM PS/2 30 


SIGNAL NAME / FUNCTION 


- Direction 

+ Write Protect 
+ Index 

- Head 1 Select 
+Track 0 

+ Step 

+ DRQ 
Interrupt 


NOOR WOND — © 


STORAGE RESET CLOCK 
ELEMENT CONDITION | QUALIFIER 
TSB N/A None 
TSB N/A None 
TSB N/A None 
TSB N/A None 
TSB N/A None 
SR F/F 0 STEP (1) 
TSB N/A None 
TSB N/A None 


Note 1: Not synchronized to unknown PAL clocks in systems compatible with the IBM PS2. 
Reset is forced to logic "0" for test purposes. Also resets to logic "0" when address 3F7 is read 


and STEP causes a set condition. 
TSB = Tri-state buffer 
SR F/F = Set Reset Flip Flop 


If Storage Element is "none", Reset Condition reflects fixed logic state. 


Status Register B (CS/ = 0 and Address = 001 - Read Only) 


TABLE 15. STATUS REGISTER B FOR SYSTEMS COMPATIBLE WITH THE IBM PS/2 50, 60, AND 80. 


SIGNAL NAME / FUNCTION STORAGE RESET CLOCK 
ELEMENT | CONDITION | QUALIFIER 


Motor Enable 0 
Motor Enable 1 
Write Enable 


Read Data | Toggle F/F 
Write Data Toggle F/F 
Drive Select TSB 
Reserved Unused TSB 
Reserved Unused TSB 


NOOR WD =— © 


Note 1: Not synchronized to unknown PAL clocks in systems compatible with the IBM PS/2 50, 
60 and 80. Reset is forced to logic "0" for test purposes. 


Note 2: Not synchronized to unknown PAL clocks in systems compatible with the IBM PS/2 50, 
60 and 80. Reset is forced to logic "0" for test purposes. This "WD" clock is an internal signal 
not qualified by WE/ signal. 


Note 3: This status reflects Digital Output Register bit 0 only. 


TABLE 16. STATUS REGISTER B FOR SYSTEMS COMPATIBLE WITH IBM PC XT AND IBM PS/2 MODEL 30 


CLOCK 
QUALIFIER 


- Drive Select 2 TSB 
- Drive Select 3 TSB 
Write Enable SR F/F 
Read Data SR F/F 
Write Data SR F/F 
- Drive Select 0 TSB 


- Drive Select 1 TSB 
Reserved Unused TSB 


0 
1 
2 
3 
4 
5 
6 
7 


Note 4: Not synchronized to unknown PAL clocks in systems compatible with IBM PS/2 30. 

Reset is forced to logic "0" for test purposes and when reading address 357. WE/, RDD/ and 

WD/ are internal signals and cause a set condition. 

Note 5: Drive select signals (0-3) are qualified by Motor Enable signals (0-3) 

TSB = Tri-state Buffer 

SR F/F = Set Reset Flip Flop. 
D 
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Data Register 


The eight-bit Data Register stores data, commands, parameters, and FDD status information. Data bytes 
are read out of, or written into, the Data Register in order to program or obtain the results after a par- 
ticular command. The relationship between the Master Status Register and the Data Register and the 
signals RD/, WR/, CS/ and AO-A2 are shown in Table 17. 


TABLE 17. MASTER STATUS AND DATA REGISTERS RELATIONSHIP 


WR FUNCTION 
1 Read Main Status Register 
1 Read from Data Register 
0 Write into Data Register 


2000/9) 
oo =| 


Digital Output Register (CS/=0 and Address = 010 - Write Only) 


The Digital Output Register (DOR) provides support logic that latches the data bus upon receiving CS/, 
Address = 010 and WR’. This register replaces the typical latched port seen in floppy subsystems used 
to control disk drive spindle motors and select drives. Table 18 illustrates the bit decode (bits 0 and 1 of 
We a used to select drives 0 through 2. Table 19 provides a bit descsription of the contents of the 


TABLE 18. BIT DECODE FOR DRIVE SELECT 
DRIVE 
Drive 0 
Drive 1 


Drive 2 
Not Supported 


TABLE 19. DIGITAL OUTPUT REGISTER 
SIGNAL FUNCTION 


Drive Select. If decode select is "0" and MOENO/ 
is active low, then DSO/ is selected. If decode 
select is "1" and MOENT7/ is active low, then DS1/ 
is selected. If decode select is "2" and MOENZ2/ is 
active low, then DS2/ is selected if in a mode 
compatible with the IBM PC XT and IBM PS/2 
Model 30. Although DS2/ is undefined in applica- 
tions compatible with the IBM PS/2 50, 60 and 80, 
the WD57C65 supports DS2/ in both modes. 


Drive Select 
Soft Reset, active low 


DMA Enable. Active in a mode compatible with 
the IBM PC XT and IBM PS/2 Model 30, qualifies 
DMA and IRQ outputs and also DACK/input. In 
modes compatible with the IBM PS/2 models 50, 
60 and 80 this internal signal is always valid. 


SA SA ea a ere RP SN ee RN OS EE dR OA A ee OR ce TED 
BIT SIGNAL COMMENTS 


DOR 4 MOENO Motor enable (Inverted output is MOENO/) | 


DOR 5 MOEN1 Motor enable (Inverted output is MOEN1/) | 


Motor enable (Inverted output is MOEN2/) Un- 


defined in applications compatible with the IBM 
PS/2 50, 60 and 80, but supported by the 
WD57C65 in both modes.) 


Reserved 


TABLE 20. DIGITAL OUTPUT REGISTER FOR SYSTEMS COMPATIBLE WITH IBM PS/2 50,60, AND 80 


BIT SIGNAL NAME / FUNCTION STORAGE RESET CLOCK 
ELEMENT | CONDITION | QUALIFIER 
0 (1) 


0 Drive Select F/F None 

1 Drive Select F/F 0 None (1) 
2 - Reset F/F 0) None | 
3 Reserved Unused F/F None 

4 Motor 0 F/F None 

5 Motor 1 F/F None 

6 Motor 2 F/F None (1) 
7 Reserved Unused F/F None 


Note 1: Although undefined in applications compatible with the IBM PS/2 50, 60 and 80, this 
signal is supported by the WD57C65. _ 


TABLE 21. DIGITAL OUTPUT REGISTER FOR SYSTEMS COMPATIBLE WITH IBM PC XT AND IBM PS/2 30. 


BIT SIGNAL NAME / FUNCTION STORAGE RESET CLOCK 
ELEMENT CONDITION | QUALIFIER 
0 


Drive Select None 
Drive Select 0 None 
- Reset None 
DMA and Interrupt Enable None 
Motor 0 None 
Motor 1 None 
Motor 2 | None 
Reserved None (2) 


Note 2: This bit is defined as Motor Enable 3 in models compatible with the IBM PS/2 30, but 
WD57C65 does not support It. 
TSB = Tri-state Buffer F/F = Flip Flop 


ii Storage Element is "none", Reset condition refiecis fixed iogic state. 


0 
1 
2 
3 
4 
5 
6 
7 
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Digital Input Register (CS/=0 and Address = 111 - Read only) 


TABLE 22. DIGITAL INPUT REGISTER FOR SYSTEMS COMPATIBLE WITH THE IBM PS/2 50, 60 AND 80 


BIT SIGNAL NAME / FUNCTION STORAGE RESET CLOCK 
ELEMENT | CONDITION | QUALIFIER 


0 - High Density Select TSB 

1 Reserved 

2 Reserved Unused TSB 
3 Reserved Unused TSB 
4 Reserved Unused TSB 
5 Reserved Unused TSB 
6 Reserved 

7 Disk Change 


Reserved 
250K Rate Select 
No Write Precompensation 


DMA, Interrupt Enable 

Reserved 

Reserved 

Reserved Unused TSB 
- Disk Change TSB 


0 
1 
2 
3 
4 
5 
6 
7 


TSB = Tri-state Buffer 
F/F = Flip Flop 
lf Storage Element is "none" or "unused", Reset Condition reflects fixed logic state. 
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Options Register 


TABLE 24. OPTIONS REGISTER 
SIGNAL | FUNCTION 


Boot Disk Select If "0", causes DS1/ and MOEN/1 to be swapped in 
H/W with DSO/ and MOENO/. Therefore, if DOR 
selects Drive 0, then actually Drive #1 will be 
selected and enabled, allowing a S/W operating 
system to be booted from the disk drive. 


SWTC Software Terminal Count allows a TC to be issued 
to the core controller under BIOS driver control. 


These two bits define the precompensation 
values, as shown in the truth table below. 


This bit disables write Poe be acdse in modes 
compatible with IBM PS/2 50, 60 and 80 only. 


BIT 3 BIT 2 PRECOMP VALUE 


0 +/- 1 Clocks 
0 +/- 2 Clocks * 
1 +/- 3 Clocks 
1 +/- 4 Clocks 


* RST Default 


Note: Clk = Clk 1 for all data rates, except when 300 Kb/s is selected which requires Clk 2. In 
PS/2 model 30 precompensation can be disabled by using bit 2 in the Configuration Control 
Register. In PS/2 50, 60 and 80, bit 4 of the Options Register disables precompensation. 


TABLE 25. TRUTH TABLE 


TABLE 26. OPTIONS REGISTER 


BIT SIGNAL NAME / FUNCTION STORAGE RESET CLOCK 
ELEMENT | CONDITION | QUALIFIER 


Boot Disk Select 

SWTC 

PCV 

PCV 

No Write Precompensation 


Reserved | Unused F/F 
_ Reserved Unused F/F 
Reserved Unused F/F 


NOOR WOM —- © 


SPECIFICATIONS 


ABSOLUTE MAXIMUM RATINGS - all voltages referenced to VSS 


VCC 

Voltage at any pin 
Storage Temperature 
Operating Temperature 


DC CHARACTERISTICS 
PARAMETER 

+5V Supply 

Input Low Voltage - Data Bus & XTOSC 
Input High Volt - Data Bus & XTOSC 
Input Low Threshold-Schmitt Trigger 
Input High Threshold-Schmitt Trigger 
Schmitt Trigger Input Hysteresis 

Output Low - DBx,IRQ,DMA ; lo=12.0mMA 
Output High - DBx,IRQ,DMA; lo=-5.0mA 
Output Low - High Current; lo=48mA 
PQR trip threshold 

Latch Up Current Low 

Latch Up Current High 

Leakage Current Low 

Leakage Current High 

Supply Current - 100uUA source loads 
Supply Current - 5mA source loads 
Power Dissipation - ICC max * 

Power Dissipation - ICCHL max * 


7.0 Volts 
-0.3 to VCC +0.3 Volts 
-55° to +150° C 


0° to +70° C 
SYMBOL MIN 
VCC 4.5 
VIL 
VIH 2.0 
VILT 0.8 
VIHT 
VIHYS 0.45 
VOL 
VOH 2.8 
VOLHC | 
VPQR 2.75 
ILUL 40 
ILUH -40 
ILL 
ILH 
ICC 
ICCHL 
PD 
PDHL 


* Includes open drain high current drivers at Vol = 0.4V 


TIMING CHARACTERISTICS (CL=100pf): 


PARAMETER 

Clock Period 

Clock Active (High or Low) 

Clock Rise Time (Vin 0.8 to 2.0) 
Clock Fall Time (Vin 2.0 to 0.8) 
A0-2 Set Up Time to RD- low 
A0-2, Hold Time to RD- high 

CS-, DACK Set Up Time to RD- low 
CS-, DACK Hold Time to RD- high 
RD- Width 

Data Access Time from RD- low 


SYMBOL MIN 

tCY 60 

tPH 25 

tR 

tF 

tAR 10 

tRA 

tCDR 0 

tRCD 0 

tRR 80 
— tRD 
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MAX 
5.5 
0.8 


2.0 


0.4 


0.4 


4.35 


10 
-10 
40 
90 
400 
950 


MAX 


70 


= 
el 


<<< << << << < C 


UNIT 


PARAMETER SYMBOL MIN MAX UNIT. 
DB to Float Delay from RD- high tDF 10 40 ns 
A0-2 Set Up Time to WR- low ~ tAW 10 ns 
AQ-2, Hold Time to WR- high tWA 0 ns 
CS-, DACK Set Up Time to WR- low tCDR 0 ns 
CS-, DACK Hold Time to WD- high tRCD 0 ns 
WR- Width tWW 60 ns 
Data Set Up Time to WR- high tDW 60 ns 
Data Hold Time from WR- high tWD @) ns 
IRQ Reset Delay Time from RD- high tRl 1MCY+100nS 
IRQ Reset Delay Time from WR- high tWI 1MCY+100nS 
DMA Cycle Time tMCY 52 MCY 
DMA Reset Delay Time from DACK- low tAM 80 ns 
DACK- Delay Time from DMA high tMA 0 ns 
DACK- Width tAA 80 MCY 
TC Width | {TC 60 ns 
Reset Width - TTL driven CLK1 tRST 60 nS 
Reset Width - Software Reset tSRST 5 MCY 
RDD- Active Time Low tRDD 40 ns 
WD- Write Data Width Low tWDD 1/2 (typ) WCY 
DIRC- Hold & Set Up to STEP- low tDST 4 MCY 
DSx- Hold time from STEP- low tSTU 20 MCY 
STEP- Active Time Low tSTP 24 MCY 
STEP- Cycle Time tSC 132 MCY 
DIRC- Hold Time after STEP- tSTD 96 MCY 
IDX- Index Pulse Width tIDX 2 MCY 
RD- Delay from DMA tMR 0 ns 
WR- Delay from DMA tMW 0 ns 
RD- or WR- Response from DMA high tMRW 48 MCY 
Chip Access Delay from RST low - TTL tCA 32 MCY 
Chip Access Delay from SRST- low tCAS 40 MCY 
Chip Access Delay - osc XT1 at 16 MHz tXCA 500 us 
TC Delay from last DMA or IRQ, RD- tTCR 0 192 MCY 
TC Delay from last DMA or IRQ, WR- tTCW 0 384 MCY 


Note: 


« MCY: 


500 KByte MFM = 250 nsec. 
250 KByte MFM = 500 nsec. 
CLK: | 


1) CY = CLK1 or XT1 period 
2) MCY = MCLK period, dependent on selected 


data rate ? | 
3) WCY = WCLK period, dependent on selected 8.0 MHz = 125 nsec. 
data rate 4.0 MHz = 250 nsec. 


4) Timing based on 3.5-inch floppy data rates. 2.0 MHz = 500 nsec. 
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FIGURE 7. READ TIMING 
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FIGURE 8. WRITE TIMING 
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FIGURE 9. DMA TIMING 
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FIGURE 11. RESET TIMING 
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FIGURE 12. DISK DRIVE TIMING 
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FIGURE 13. CLOCK TIMING 


COMMAND SUMMARY 


Command Parameters 


The WD57C65 performs 15 different host sup- 
plied commands: 


READ DATA 

READ DELETED DATA 
WRITE DATA 

WRITE DELETED DATA 
READ A TRACK 

READ ID 

FORMAT A TRACK 
SCAN EQUAL 

SCAN LOW OR EQUAL 
SCAN HIGH OR EQUAL 
RECALIBRATE 

SENSE INTERRUPT STATUS 
SPECIFY 

SENSE DRIVE STATUS 
SEEK 


A multibyte transfer from the processor initiates 
each command. The results after execution of the 
command may also be a multibyte transfer back 
to the processor. The commands consist of three 
phases: the command phase, the execution 
phase, and the result phase. 


Command phase - The Floppy Disk Controller 
(FDC) receives all information required to perform 
a particular operation from the processor. 


Execution phase - The FDC performs the opera- 
tion it was instructed to do. 


Result phase - After completion of the operation, 
status and other housekeeping information are 
available to the processor. 


Tables 27 through 41 show the required 
parameters and results for each command. Most 
commands require nine command bytes and 
return seven bytes during the result phase. The 
"W" to the left of each bytes indicates a command 
pase byte to be written. An "R" indicates a result 

yte. Table 42, page 35, lists and defines all of 
the symbols used in tables 27 through 41. 


TABLE 27. READ DATA 


__PHASE _| R/W | 07| D6] 05/04! _|03/ 02| Di] Oo] __REMARKS 


COMMAND 0| Command Codes 


Sector ID information prior to command 
execution. The four bytes are compared 
against header on floppy disk. 


W 
W 
W 
WwW 
WwW 
W 
WwW 
WwW 
W 


Data transfer between FDD and main 
system. 


RESULTS 


execution. 


Sector ID information after command 
execution. 


TABLE 28. READ DELETED DATA 


ee Se ee 


COMMAND 0| Command Codes 


Sector ID information prior to command 
execution. The four bytes are compared 
against header on floppy disk. 


SzSzzzz=zz=z 


RESULTS Status information after command 


execution. 


Sector ID information after command 
execution. 


DDUVIIIVID 
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TABLE 29. WRITE DATA 


a oe ee 


COMMAND Command Codes 


Sector ID information prior to command 
execution. The four bytes are compared 
against header on floppy disk. 


W 
W 
W 
W 
W 
W 
WwW 
W 
W 


RESULTS Status information after command 
execution. 


Sector ID information after command 
execution. 


TABLE 30. WRITE DELETED DATA 


COMMAND 


Sector ID information prior to command 
execution. The four bytes are compared 
against header on floppy disk. 


RESULTS 


Status information after command 
execution. 


Sector ID information after command 
execution. 


DUVVDVVD 
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TABLE 31. READ A TRACK 


eae ee a 


COMMAND 0| Command Codes 


Sector ID information prior to command 
execution. 


W 
W 
W 
W 
W 
W 
W 
W 
W 


Data transfer between FDD and main 
system. FDD reads all data fields from 
index hole to EOT. 


RESULTS Status information after command 
execution. 


Sector ID information after command 
execution. 


TABLE 32. READ ID 


2 BASE UW POE Be 8 Oe | Bape, 


COMMAND v3 : sy 0; O 20) __—__REMARKS Codes 
X| xX 4" ae is, e5 
EXECUTION The first correct ID information on the 
cylinder is stored in Data Register. 
RESULTS Status information after command 
execution. 


Sector ID information read during 
Execution Phase from floppy disk. 
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TABLE 33. FORMAT A TRACK 


pase RW [6705s] oa] — [oa[ 62 vi bo| ——rewanns 


COMMAND Command Codes 


Bytes/Sector 
Sectors/Track 
Gap 3 

Filler Byte 


RESULTS Status information after command 
execution. 


In this case, the ID information has no 
meaning. 


TABLE 34. SCAN EQUAL 


2 ee a. ee 


COMMAND Command Codes 


Sector ID information prior to command 
execution. 


SS5555555| 


RESULTS » 


Sector ID information after command 
execution. 


DUVUIDIIVI 
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TABLE 35. SCAN LOW OR EQUAL 


Be ee ee 


COMMAND Command Codes 


== 


Sector ID information prior to command 
execution. 


W 
W 
W 
W 
W 
W 
W 


RESULTS information after command 
execution. 


TABLE 36. SCAN HIGH OR EQUAL 


ee a 


COMMAND Command Codes 


Sector ID information prior to command 
execution. 


Setszszezzz2= 


RESULTS 
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TABLE 37. RECALIBRATE 


| D7| D6! D5, 


COMMAND iM 0; oO} OO; O a Pol _—_REMARKS Codes 
X}| Xi Xi xX X ss ep 


EXECUTION AEN Head retracted to Track zero, 


TABLE 38. SENSE INTERRUPT STATUS 


PHASE [RAW [p7[Dé[D5[b4] [9] bal Di] bol REMARKS 
mate a ea ee 


RESULTS oS Status information about the FDC at the 
PCN—_———_-————->|_ end of seek operation. 


TABLE 39. SPECIFY 


_R/W | D7/D6/D5| D4! __| D3 D2) 


W 0; O| O| QO 0 Heong MAS | Codes 
W <SRI > <n 
WwW | <————_-HLT 


TABLE 40. SENSE DRIVE STATUS 
a Ce 


COMMAND c an EMA Codes 
7 . : : me et USO 


RESULTS Sa ey Pametecminesniia eran Status information about the FDC. 


COMMAND 


TABLE 41. SEEK 


[PHASE | RIW [7| Dé] Ds 


COMMAND -bo___REMARKS __ Codes 
ac ey ge 
a 


ae Head is positioned over proper eae 
on the eae 
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TABLE 42. COMMAND SYMBOL DESCRIPTIONS 


SYMBOL| == NAME | DESCRIPTION 


ADDRESS LINE 0 


CYLINDER NUMBER 


DATA 
DATA BUS 


DATA LENGTH 


END OF TRACK 


GAP LENGTH 


HEAD ADDRESS 
HEAD LOAD TIME 


HEAD SELECT 
HEAD UNLOAD TIME 


FM or MFM 
MULTITRACK 


NUMBER 


NEW CYLINDER 
NUMBER 


NON-DMA MODE 
PRESENT CYLINDER 


RECORD 
READ/WRITE 
SECTOR 

SKIP 

STEP RATE TIME 


AO controls selection of Main Status Register (AO=0) or Data Register 
(AO=1). 


C stands for the current/selected cylinder (track) numbers 0 through 
255 of the medium. 
D stands for the data pattern which is going to be written into a sector. 


8-bit DATA BUS, where D7 stands for a most significant bit, and DO 
stands for a least significant bit. 


When N is defined as 00, DTL stands for the DATA LENGTH which users 
are going to read out or write into the sector. 


EOT stands for the final sector number on a cylinder. During Read or 
Write operations, FDC will stop data transfer after a sector number equal 
to EOT. 


GPL stands for the length of Gap 3. During the FORMAT Command, 
it determines the size of Gap 3. 


H stands for head number 0 or 1, as specified in the ID field. 


HLT stands for the HEAD LOAD TIME in FDD (2 to 254ms in 2ms 
increments). 


HS stands for a selected head number 0 or 1 and controls the polarity 


of pin 25 (in 40 pin DIP) or pin 28 (in 44 pin PLCC). 


HUT stands for the HEAD UNLOAD TIME after a Read or Write 
operation has occurred (16 to 240ms in 16ms increments). 


If MF is low, FM mode is selected. If it is high, MFM mode is selected. 


If MT is high, a MULTITRACK operation is performed. If MT=1 after 
finishing Read/Write operation on side 0, FDC will automatically start 
searching for sector 1 on side 1. 


N stands for the NUMBER of data bytes written in a sector. 


NCN stands for a NEW CYLINDER NUMBER which is going to be 
reached as a result of the Seek operation. Desired position of head. 


ND stands for operation in the NON-DMA MODE. 


PCN stands for the cylinder number at the completion of the SENSE 
INTERRUPT STATUS Command. Position of head at present time. 


R stands for the sector number which will be read or written. 
R/W stands for either READ or WRITE signal. 

SC indicates the number of sectors per cylinder. 

SK stands for SKIP Deleted Data Address mark. 


SRT stands for the Stepping Rate for the FDD (1 to 16ms in 1ms 
increments). Stepping Rate applies to all drives. In 2’s complement 
format, F(Hex)=1ms, E(Hex)=2ms, etc. 
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TABLE 42. COMMAND SYMBOL DESCRIPTIONS (CONTINUED) 


SYMBOL| = NAME | DESCRIPTION 


STATUS 0 
STATUS 1 
STATUS 2 
STATUS 3 


STO — 3 stands for one of four registers which store the STATUS 
information after a command has been executed. This information 
is available during the result phase after command execution. 
These registers should not be confused with the Main Status Register 
(selected by AO=0). STO — 3 may be read only after a command has 


been executed and contains information relevant to that particular 


command. 


STP During a SCAN operation, if STP=1, the data in contiguous sectors 
is compared byte by byte with data sent from the processor (or DMA); 
if STP=2, then alternate sectors are read and compared. 


USO,US1 UNIT SELECT 


Command Descriptions 


Read Data 


A set of nine byte words are required to place the 
FDC into the Read Data Mode. After the Read 
Data command has been issued, the FDC loads 
the head (if it is in the unloaded state), waits for 
the specified head settling time (defined in the 
Specify Command), and begins reading ID Ad- 
dress Marks and ID fields. When the current sec- 
tor number (R) stored in the ID Register (IDR) 
compares with the sector number read off the dis- 
kette, then the FDC outputs data (from the data 
ie byte-to-byte to the main system via the data 
us. 


After completion of the read operation from the 
current sector, the Sector Number is incremented 
by one, and the data from the next sector is read 
and placed on the data bus. This continuous 
read function is called a "Multi-sector Read 
Operation." The Read Data Command may be 
terminated by the receipt of a Terminal Count 
signal. TC should be issued at the same time as 
the DACK/ for the last byte of data. Upon receipt 
of this signal, the FDC stops outputting data to the 
processor, but continues to read data from the 
current sector, check CRC (Cyclic Redundancy 
Count) bytes, and terminate the Read Data com- 
mand at the end of the sector. The amount of data 
handled by a single command to the FDC 
depends upon MT (multi-track), MF (MFM/FM), 
and N (number of bytes/sector). Table 43 lists the 
Transfer Capacity. 


The "multi-track" function (MT) allows the FDC to 
read data from both sides of the diskette. For a 


US stands for a selected drive; binary encoded, 1 of 4. 


TABLE 43. TRANSFER CAPACITY 


Final Sector 
Read from 
Diskettes 

26 at Side 0 

or 26 at Side 1 


26 at Side 1 


Multi- MFM/ Bytes/ Maximum Transfer Capacity 
Track FM Sector (Bytes/Sector) 
M N (Number of Sectors) 
0 (128) (26) = 3,328 
(256) (26) = 6,656 
(128) (52) = 6,656 
01 (256) (52) = 13,312 


fo) 


oo|-—|o 


0 (256) (30) = 7,680 oes 
0 (512) (30) = 15,360 dear oldest 


0 0 (512) (8) = 4,096 8 at Side 0 
0 (1024) (8) = 8,192 or 8 at Side 1 
0 


1 
0 


1 
0 
1 
0 01 (256) (15) = 3,840 15 at Side 0 
1 02 (512) (15) = 7,680 or 15 at Side 1 
0 1 
{ 


oO}; = 


Oo 


particular cylinder, data will be transferred starting 
at Sector 1, Side 0 and completing at Sector L, 
Side 1 (Sector L = last sector on the side). Note: 
this function pertains to only one cylinder (the 
same track) on each side of the diskette. 


When N = 0, then DTL defines the data length as 
a sector. If DTL is smaller than the actual data 
length of a sector, the data beyond DTL in the 
sector is not sent to the Data Bus. The FDC 
reads (internally) the complete sector performing 
the CRC check, and depending upon the manner 
of command termination, may perform a Multi- 
Sector Read operation. When N is non-zero, then 
DTL has no meaning and sets to FF 
(hexadecimal.) 


Upon completion of the Read Data command, 
and after Head Unload Time Interval (specified in 
the Specify command) has elapsed, the head un- 


loads. If the processor issues another command 
before the head unloads, then the head settling 
time may be saved between subsequent reads. 
This time out is particularly valuable when a dis- 
kette is copied from one drive to another. 


If the FDC detects the Index Hole twice without 
finding the right sector, (indicated in "R"), then the 
FDC sets the ND (No Data) flag in Status Register 
1 to a "1" (high), and terminates the Read Data 
command. (Status Register 0 also has bits 7 and 
6 set to "0" and "1", respectively.) 


After reading the ID and Data Fields in each sec- 
tor, the FDC checks the CRC bytes. If it detects a 
read error (incorrect CRC in ID field), the FDC 
sets the DE (Data Error) flag in Status 
Register 1 to "1" (high). If a CRC error occurs in 
the Data Field, the FDC also sets the DD (Data 
Error in Data Field) flag in Status Register 2 to a 
"{" (high), and terminates the Read Data com- 
mand. (Status Register 0 also has bits 7 and 6 set 
to "0" and "1", respectively.) 

If the FDC reads a Deleted Data Address Mark off 
the diskette, and the SK bit (bit D5 in the first 
Command Word) is not set (SK = 0), then the 
FDC sets the CM (Control Mark) flag in status 
Register 2 to a "1" (high), and terminates the 
Read Data command, after reading all the data in 
the sector. If SK = 1, the FDC skips the sector 
with the Deleted Data Address Mark and reads 
the next sector. The CRC bits in the deleted data 
field are not checked when SK = 1. 


During disk data transfers between the FDC and 
the processor, via the data bus, the processor 
must service the FDC every 27 microseconds in 
the FM mode, and every 13 microseconds in the 
MFM mode. If not, the FDC sets the OR (Overrun) 
flag in Status Register 1 to a "1" (high), and ter- 
minates the Read Data command. 


If the processor terminates a read (or write) 
operation in the FDC, then the ID information in 
the Result phase is dependent upon the state of 
the MT bit and EOT byte. Table 44 shows the 
values for C, H, R, and N, when the processor ter- 
minates the command. 


Write Data 


The FDC requires nine bytes of command for the 
Write Data mode. After the Write Data command 
issues, the FDC loads the head (if it is in the un- 
loaded state), waits the specified head settling 
time (defined in the Specify command), and 
- begins reading ID fields. When all four bytes 
loaded during the command (C,H,R,N) match the 


TABLE 44. C, H, R, AND N VALUES 


ID Information at Result Phase 


Final Sector Transferred 
to Processor 


MT HD 


Notes: NC (No Change): The same value as the one at the beginning of command 
execution. LSB (Least Significant Bit): The least significant bit of H is 
complemented. 


four bytes of the ID field from the diskette, the 
FDC takes data from the processor byte-by-byte 
via the data bus and outputs it to the FDD. 


After writing data into the current sector, the sec- 
tor number stored in "R" is incremented by one, 
and the next data field is written. The FDC con- 
tinues this Multi-Sector Write Operation until the 
issuance of a Terminal Count signal. If a Terminal 
Count signal is sent to the FDC, the FDC con- 
tinues writing into the current sector to complete 
the data field. If the Terminal Count signal is 
received while a data field is being written, then 
the remainder of the data field is filled with zeros. 
The FDC reads the ID field of each sector and 
checks the CRC bytes. If the FDC detect a read 
error (CRC error) in one of the ID fields, it sets the 
DE (Data Error) flag of Status Register 1 to a "1" 
(high) and terminates the Write Data command. 
(Status Register 0 also has bits 7 and 6 set to "0" 
and "1", respectively.) 

The Write command operates in much the same 
manner as the Read command. The following 
items are the same, and one should refer to the 
Read Data command for details: 


¢ Transfer Capacity 

¢ EN (End of Cylinder) flag 

¢ ND (No Data) flag 

¢ Head Unload Time interval 


¢ ID Information when the processor terminates 
command 


Definition of DTL when N = 0 and when N#0 


In the Write Data mode, data transfers between 
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the processor and FDC via the data bus, must 
occur every 27 microseconds in the FM mode and 
every 13 microseconds in the MFM mode. If the 
time interval between data transfers is longer than 
this, then the FDC sets the OR (Overrun) flag in 
Status Register 1 to a "1" (high) and terminates 
the Write Data command. (Status Register 0 also 
has bits 7 and 6 set to "0" and "1", respectively.) 


Write Deleted Data 


This command is the same as the Write Data 
command except a Deleted Data Address mark is 
written at the beginning of the data field instead of 
the normal Data Address mark. 


Read Deleted Data 


This command is the same as the Read Data 
command except that when the FDC detects a 
Data Address mark at the beginning of a data field 
(and SK = 0 [low)), it will read all the data in the 
sector and set the CM flag in Status Register 2 to 


a "1" (high), and then terminate the command. If — 


SK = 1, then the FDC skips the sector with the 
Data Address mark and reads the next sector. 


Read A Track 


This command is similar to the Read Data com- 
mand, except that this is a continuous Read 
operation where the entire data field from 
each of the sectors is read. Immediately after 
sensing the index hold, the FDC starts reading all 
data fields on the track as continuous blocks of 
data. If the FDC finds an error in the ID or 
Data CRC check bytes, it continues to read data 
from the track. The FDC compares the ID infor- 
mation read from each sector with the value 
stored in the IDR. It sets the ND flag of the Status 
REgister 1 to a "1" (high) if there is no com- 
parison. Multi-Track or skip operations are not al- 
lowed with this command. 


This command terminates when the number of 
sectors read is equal to EOT. If the FDC does not 
find an ID Address mark on the diskette after it 
senses the index hold for the second time, it sets 
the MA (missing Address mark) flag in Status 
Register 1 to a"1" (high) and terminates the com- 
mand. (Status Register 0 has bits 7 and 6 set to 
"0" and "1", respectively.) 

Read ID 


The Read ID command is used to give the 
present position of the recording head. The FDC 
stores the values from the first ID field it is able to 
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read. If no proper ID Address mark is found on the 
diskette before the index hole is encountered for 
the second time, then the MA (Missing Address 
mark) flag in Status Register 1 is set to a "1" 
(high). If no data is found, then the ND (No 
Data) flag is also set in Status Register 1 to a "1" 
(high). The command is then terminated with bits 
7 and 6 in Status Register 0 set to "0" and "1", 
respectively. During this command there is no 
data transfer between FDC and the CPU except 
during the result phase. 


Format A Track 


The Format command allows an entire track to be 
formatted. After the index hole is detected, data is 
written on the diskette: Gaps, Address marks, ID 
fields and data fields, all per the IBM System 34 
(double density) or System 3740 (single density) 
format are recorded. The particular format which 
will be written is controlled by the values 
programmed into N (number of bytes/sector), 
SC (sectors/cylinder), GPL (gap length), and D 
(data pattern) which the processor supplies during 
the command phase. The data field is filled with 
the byte of data stored in D. The processor 
supplies the ID field for each sector; that is, the 
processor makes four data requests per sector for 
C (cylinder number), H (head number), R (sector 
number) and N (number of bytes/sector). This al- 
lows the diskette to be formatted with nonsequen- 
tial sector numbers, if desired. 


The processor must send new values for C, H, R, 
and N to the WD57Cé65 for each sector on the 
track. If FDC is set for the DMA mode, it will issue 
four DMA requests per sector. If it is set for the In- 
terrupt mode, it will issue four interrupts per sector 
and the processor must supply C, H, R, and N 
loads for each sector. The contents of the R 
register are incremented by "1" after each sector 
is formatted; thus, the R register contains a value 
of R when it is read during the Result phase. This 
incrementing and formatting continues for the 
whole track until the FDC detects the index hole 
for the second time, whereupon it terminates the 
command. 


Table 45 shows the relationship between N, SC, 
and GPL for various sector sizes. 


TABLE 45. N, SC, AND GPL RELATIONSHIP 


Format Sector Size N Sc GPL GPL2 3 
8” Standard Fio 


128 bytes/sector 00 1A 


07 1B 
256 01. OF OF 2A 

512 02 08 1B 3A 

FM Mode 4994 03.04.47 BA 
2048 04. 02 #28 FF 

4096 05 «01 C8 FF 

256 01. 1A OE 36 

512 02. OF 1B 54 

MFM 1024 03.08 35 74 
Mode4 2048 04-04 99 FF 
4096 05 02 C8 FF 

8192 06 1 C8 FF 

128 bytes/sector 00 12 07 09 

128 00 10 10 19 

256 01 08 18 30 

FM Mode 542 02. 04 46 87 
1024 03. 02 ~+2C8 FF 

2048 04. =O C8 FF 

256 01. (12 OA oC 

256 01-10 20 32 

512 02. 08 2A 50 

MFM 1024 03. 04 80 FO 
Mode4 2048 04 02 #8 FF 
4096 05 01 C8 FF 

3%2” Sony Microflopp 

128 bytes/sector 0 OF 07 1B 

FM Mode 256 1 09 OE 2A 
512 2 05 1B 3A 

256 1 OF OE 36 

ie 2 209 1B 54 
nee 1024 3 05 35 74 


Notes: ' Suggested values of GPL in Read or Write commands 

to avoid splice point between data field and |D field of 

contiguous sections. 

Suggested values of GPL in format command. 

All values except sector size are hexidecimal. 

4 In MFM mode FDC cannot perform a Read/Write/format 
operation with 128 bytes/sector. (N = 00) 


WN 


Scan Commands 


The Scan commands allow data which is being 
read from the diskette to be compared against 
data which is being supplied from the main sys- 
tem. The FDC compares the data on a byte-by- 
byte basis and looks for a sector of data which 
meets the conditions of DFpp = DProcessor, DEDD < 
DProcessor; or DFpp > DProcessor. The 
hexadecimal byte of FF either from memory or 
from FDD, can be used as a mask byte because it 
always meets the condition of the comparison. 
One’s complement arithmetic is used for com- 
parison (FF = largest number, 00 = smallest num- 
ber). If, after a whole sector of data is compared, 
and the conditions are not met, the sector number 


increments (R + STP ——s R), and the scan 
operation continues. The scan operation con- 
tinues until one of the following conditions occur: 
the conditions for scan are met (equal, low, or 
high), the last sector on the track is reached 
(EOT), or the terminal count signal is received. 


If the conditions for scan are met, then the FDC 
sets the SH (Scan Hit) flag of Status Register 2 to 
a "1" (high) and terminates the Scan command. If 
the conditions for scan are not met between the 
starting sector (as specified by R) and the last 
sector on the cylinder (EOT), then the FDC sets 
the SN (Scan Not Satisfied) flag of Status 
Register 2 toa "1" (high) and terminates the Scan 
command. The receipt of a Terminal Count signal 
from the processor or DMA controller during the 
scan operation will cause the FDC to complete 
the comparison of the particular byte which is in 

rocess and then to terminate the command. 

able 46 shows the status of bits SH and SN 
under various conditions of Scan. 


TABLE 46. STATUS OF BITS SH AND SN 


Status Register 2 


Command Bit2 = SN Bit 3 = SH Comments 


Scan Equal 


DFEpD = DProce 

DFpD <DProcessor 
DFppD >DProcessor 
Drop = DProcessor 
Drop > DProcessor 
DFDoD < DpProcessor 


Scan Low 
or Equal 


Scan High 
or Equal 


If the FDC encounters a Deleted Data Address 
mark on one of the sectors (and SK = QO), then it 
regards the sector as the last sector on the 
cylinder, sets the CM (Control Mark) flag of Status 
Register 2 toa "1" (high) and terminates the com- 
mand. If SK = 1, the FDC skips the sector with the 
Deleted Address mark and reads the next sector. 
In the second case (SK = 1), the FDC sets the 
CM (Control mark) flag of Status Register 2 to a 
"1" (high) in order to show that a deleted sector 
had been encountered. 


During the Scan command, the processor or DMA 
controller supplies the data for comparison 
against the data read from the diskette. In order to 
avoid having the OR (Overrun) flag set in Status 


Register 1, it is necessary to have the data avail- 
able in less than 27 microseconds (FM mode) or 
13 microseconds (MFM mode). If an Overrun oc- 
curs, the FDC ends the command with bits 7 and 
6 of Status Register 0 set to "0" and "1", respec- 
tively. 

Seek 


The Read/Write head within the FDD is moved 
from cylinder to cylinder under control of the Seek 
command. FDC has four independent Present 
Cylinder Registers for each drive. They are 
cleared only after the Recalibrate command. The 
FDC compares the PCN (Present Cylinder Num- 
ber) which is the current head position with the 
NCN (New Cylinder Number), and if there is a dif- 
ference, performs the following operations: 


PCN < NCN: Direction signal to FDD set to a "1" 
(high), and step pulses are issued. (Step In) 


PCN > NCN: Direction signal to FDD set to a "0" 
(low), and step pulses are issued. (Step Out) 


The rate at which step pulses are issued is con- 
trolled by SRT (Stepping Rate Time) in the 
Specify command. After each step pulse issues, 
NCN is compared against PCN, and when NCN = 
PCN, the SE (Seek End) flag sets in Status 
Register 0 to a "1" (high), and the command ter- 
minates. At this point FDC interrupt goes high. 
Bits DOB-D3B in the Main Status Register set 
during the Seek operation and are cleared by the 
Sense Interrupt Status command. 


During the command phase of the Seek operation 
the FDC is in the FDC Busy state; but seal hatha 
Execution phase, it is in the non-busy state. While 
the FDC is in the non-busy state, another Seek 
command may be issued, and in this manner 
parallel Seek operations may be done on up to 
four drives at once. No other command can be is- 
sued for as long as the FDC is in the process of 
sending step pulses to any drive. 


If the time to write three bytes of Seek command 
exceeds 150 microseconds, the timing between 
the first two step pulses may be shorter than set 
in the Specify command by as much as 1 mil- 
lisecond. 


Recalibrate 


The function of this command is to retract the 
Read/Write head within the FDD to the Track 0 
position. The FDC clears the contents of the PCN 
counter and checks the status of the Track 0 sig- 
nal from the FDD. As long as the Track 0 signal is 
low, the Direction signal remains 0 (low) and step 
pulses are issued. When the Track 0 signal goes 


high, the SE (Seek End) flag in Status 
Register 0 is set toa "1" (high) and the command 
terminates. If the Track 0 signal is still low after 77 
step pulses have issued, the FDC sets the SE 
(Seek End) and EC (Equipment Check) flags of 
Status Register 0 to both "1s" (highs), and ter- 
minates the command after bits 7 and 6 of Status 
Register 0 are set to "0" and "1", respectively. 

The ability to do overlap Recalibrate commands to 
multiple FDDs and the loss of the Ready signal, 
as described in the Seek command, also applies 
to the Recalibrate command. 

Sense Interrupt Status 


An Interrupt signal is generated by the FDC for 
one of the following conditions: 


1. Upon entering the Result phase of: 
a. Read Data command 
b. Read A Track command 
c. Read ID command 
d. Read Deleted Data command 
e. Write Data command 
f. Format A Cylinder command 
g. Write Deleted Data command 
h. Scan commands 
2. Ready Line of FDD changes state 
3. End of Seek or Recalibrate command 
4. During Execution phase in the non-DMA mode 


Interrupts caused by reasons 1 and 4 above 
occur during normal command operations and are 
easily discernible by the processor. During an Ex- 
ecution phase in non-DMA mode, DB5 in the 
Main Status Register is high. Upon entering the 
Result phase, this bit clears. Conditions 1 and 4 
do not require Sense Interrupt Status commands. 
The interrupt clears by Reading/Writing data to 
the FDC. Interrupts caused by reasons 2 and 3 
above may be uniquely identified with the aid of 


TABLE 47. INTERRUPT CAUSE 


Interrupt Code 


Seek End 
i Bit6 Bit7 Cause 


Bit 5 
0 1 1 Ready Line changed state, either 
polarit 
1 0 0 Normal Termination of Seek or 
Recalibrate command 
1 1 0 Abnormal Termination of Seek or 
Recalibrate command 


~<«—_—— Seek (or Recalibrate) Command —————y|<«— Sense Interrupt Status Command —» 


<«— Command Phase —»|«<«— Execution Phase —» 
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RCN Read by 


OP Code for 
Processor 


FIGURE 14. SEEK, RECALIBRATE AND SENSE INTERRUPT 


the Sense Interrupt Status command. This com- 
mand, when issued, resets the Interrupt signal 
and via bits 5,6, and 7 of Status Register 0, iden- 
tifies the cause of the interrupt. 


The Sense Interrupt Status command is used in 
conjunction with the Seek and Recalibrate com- 
mands which have no Result phase. When the 
disk drive has reached the desired head position, 
the WD57C65 will set the interrupt line true. The 
host CPU must then issue a Sense Interrupt 
Status command to determine the actual 
cause of the interrupt, which could be Seek End 
or a change in ready status from one of the 
drives. See Figure 14. 


The Specify command sets the initial values for 
each of the three internal timers. The HUT (Head 
Unload Time) defines the time from the end of the 
Execution phase of one of the Read/Write com- 
mands to the head unload state. This timer is 
programmable from 16 to 240 milliseconds in in- 


crements of 16 milliseconds (01 = 16 mil- 
liseconds, 02 = 32 milliseconds .. . OFi6 = 240 
milliseconds). The SRT (Step Rate Time) defines 
the time interval between adjacent step pulses. 
This timer is programmable from 1 to 16 mil- 
liseconds in increments of 1 millisecond (F = 1 
millisecond, E = 2 milliseconds, D = 3 mil- 
liseconds, etc.). The HLT (Head Load Time) 
defines the time between when the Head Load 
signal i high and the Read/Write operation 
starts. This timer is programmable from 2 to 254 
milliseconds in increments of 2 milliseconds (011 
= 2 milliseconds, 02 = 4 milliseconds, 03 = 6mil- 
liseconds ...7F = 254 milliseconds). 


The time intervals mentioned above are a direct 
function of the clock (CLK on pin 20). Times indi- 
cated above are for a 16 MHz clock; if the clock 
was reduced to 8 MHz, then all time intervals 
are increased by a factor of 2. 


\ 


The choice of DMA or non-DMA operation is 
-made by the ND (Non-DMA) bit. When this bit is 
high (ND = 1), the Non-DMA mode _ is 
selected; and when ND = 0, the DMA mode is 
selected. 


Sense Drive Status 


The processor uses this command whenever it 
wishes to obtain the status of the FDDs. Status 
Register 3 contains the Drive Status information 
stored internally in FDC registers. 

Invalid 

lf an Invalid command is sent to the FDC (a com- 
mand not defined above), then the FDC will ter- 


minate the command after bits 7 and 6 of Status 
Register 0 are set to "1" and "0", respectively. No 
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interrupt is generated during this condition. Bits 6 
and 7 (DIO and RQM) in the Main Status Register 
are both high (1), indicating to the processor that 
the WD57C65 is in the result phase and the con- 
tents of Status Register 0 (STO) must be read. 
When the processor reads Status Register 0, it 
will find 80 hex, indicating an Invalid command 
was received. 


A Sense Interrupt Status command must follow 
after a Seek or Recalibrate interrupt; otherwise 
the FDC will not consider the next command. 


In some applications, the user may wish to use 
this command as a No-Op command to place the 
FDC in a standby or No Operation state. 


APPENDIX 


Device Resets 


The WD57C65 supports both a hardware reset 
pin, RST, and a software reset, SRST/, through 
use of the Digital Output Register. The RST pin 
causes a device reset for the active dura- 
tion. After a hardware reset, RST active, the 
WD57C65 is held in soft reset, SRST/ active, until 
SRST/ clears ,and default selects 500K MFM (or 
250K FM, code dependent) as the data rate (16 
MHz input clock). SRST/ also causes a reset con- 
dition for the active duration, which resets the 
microcontroller like RST, but does NOT affect the 
current data rate selection. RST, when active, dis- 
ables the high current driver outputs to the disk 
drive. 


Any reset will cause an IRQ since the WD57C65 
always assumes the drive is READY. This hap- 
pens because the drive polling routine senses a 
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change in status from NOT READY to READY. In 
the IBM PC XT and IBM PS/2 Model 30, if 
DMAEN is not active for at least one millisecond 
after reset becomes inactive, the IRQ latch may 
set before it is enabled. 


If the XTAL oscillator is used, instead of a TTL 
driven clock input, the reset time requirement is 
greater. The oscillator circuit is designed so that 
RST bootstraps the circuit into oscillation within a 
fixed amount of time. The extended reset time 
allows the oscillator to achieve a stable internal 
clock timing. 


PQR (Power Qualified Reset) 

The "PQR" is a power-up and power failure reset. 
It prevents glitches at the Drive Interface upon 
power-up or during power failure. The PQR has a 
clock detection circuit to ensure that the clock is 
stable. In PQR mode all the HCD drivers are dis- 
abled and they stay in reset mode. The "PQR" 
acts exactly like "RST" (Hardware reset). 
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Radio Frequency Interference Statement 


This Western Digital product has been certified to comply with the 
limits for a Class B computing device pursuant to subpart J of Part 
115 of FCC rules. This does not guarantee that interference will not 
occur in individual installations. Western Digital is not responsible for 
any television, radio, or other interference caused by unauthorized 
modifications of this product. 


If interference problems do occur, please consult the system equip- 


ment owner’s manual for suggestions. Some of these suggestions in- 
clude relocation of the computer system away from the television or 
radio or placing the computer AC power connection on a different cir- 
cuit or outlet. 


The product was tested and certified with a shielded interconnecting 
cable; therefore, a shielded cable is required to be used with this 
product. | 
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